<template>
  <div>
    <!-- 搜索页面头部 -->
    <div class="search-header">
      <!-- 后退按钮 -->
      <van-icon
        name="arrow-left"
        color="white"
        size="0.48rem"
        class="goback"
        @click="$router.back()"
      />
      <!-- 搜索组件 -->
      <van-search
        v-fofo
        v-model.trim="kw"
        placeholder="请输入搜索关键词"
        background="#007BFF"
        shape="round"
        @input="inputFn"
        @search="serachFn"
      />
    </div>
    <!-- 搜索建议列表 -->
    <div class="sugg-list" v-if="kw.length !== 0">
      <div
        class="sugg-item"
        v-for="(str, index) in suggestList"
        :key="index"
        v-html="lightFn(str, kw)"
        @click="suggestClickFn(str)"
      ></div>
    </div>
    <!-- 搜索历史 -->
    <div class="search-history" v-else>
      <!-- 标题 -->
      <van-cell title="搜索历史">
        <!-- 使用 right-icon 插槽来自定义右侧图标 -->
        <template #right-icon>
          <van-icon name="delete" class="search-icon" @click="clearFn"/>
        </template>
      </van-cell>

      <!-- 历史列表 -->
      <div class="history-list">
        <span class="history-item"
        v-for="(str,index) in history"
        :key="index"
        @click="historyClickFn(str)"
        >{{str}}</span>
      </div>
    </div>
  </div>
</template>

<script>
import { suggestListAPI } from '@/api'
export default {
  data () {
    return {
      kw: '', // 搜索关键字
      timer: null, // 防抖定时器
      suggestList: [], // 联想建议数组
      history: JSON.parse(localStorage.getItem('his')) || []// 搜索历史
    }
  },
  methods: {
    inputFn () {
      // 防抖：延迟执行逻辑代码，事件再次触发时，清楚上一个定时器
      // 每次触发事件的时候都重新计时
      clearTimeout(this.timer)
      if (this.kw.length === 0) {
        // 将关键字清空后也要清空联想列表
        this.suggestList = []
      } else {
        this.timer = setTimeout(async () => {
          const res = await suggestListAPI({
            keywords: this.kw
          })
          console.log(res)
          this.suggestList = res.data.data.options // 获取联想数组
        }, 300)
      }
    },
    // 处理关键字高亮 originstr原来的字符创，target关键字
    lightFn (originStr, target) {
      // 字符串.replaceAll()
      // 返回值就是替换之后的字符串
      // 忽略大小写的正则//i
      // 如果要在正则中传变量，可以是使用正则对象
      const regx = new RegExp(target, 'ig') // i表示忽略大小写，g表示全局都匹配
      // match是匹配到的内容
      return originStr.replace(regx, (match) => {
        return `<span style="color:red;">${match}</span>`
      })
    },
    moveFn (theKw) {
      setTimeout(() => {
        this.$router.push({
          path: `/search_result/${theKw}`
        })
      })
    },
    // 输入框 - 搜索事件
    serachFn () {
      if (this.kw.length > 0) {
        this.history.push(this.kw)
        this.moveFn(this.kw)
      }
    },
    // 联想菜单 - 点击事件
    suggestClickFn (str) {
      this.history.push(this.kw)
      this.moveFn(str)
    },
    // 搜索历史 - 点击事件
    historyClickFn (str) {
      this.$router.push({
        path: `/search_result/${str}`
      })
    },
    // 清楚历史记录
    clearFn () {
      this.history = []
    }
  },
  // watch侦听器的使用
  watch: {
    history: {
      deep: true,
      handler () {
        // 立刻覆盖式的保存到本地
        const theSet = new Set(this.history)
        const arr = Array.from(theSet)
        localStorage.setItem('his', JSON.stringify(arr))
      }
    }
  }
}
</script>

<style scoped lang="less">
.search-header {
  height: 46px;
  display: flex;
  align-items: center;
  background-color: #007bff;
  overflow: hidden;
  /*后退按钮*/
  .goback {
    padding-left: 14px;
  }
  /*搜索组件*/
  .van-search {
    flex: 1;
  }
}
/*搜索建议列表样式 */
.sugg-list {
  .sugg-item {
    padding: 0 15px;
    border-bottom: 1px solid #f8f8f8;
    font-size: 14px;
    line-height: 50px;
    // 实现省略号的三行代码
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
/**搜索历史 */
.search-icon {
  font-size: 16px;
  line-height: inherit;
}

.history-list {
  padding: 0 10px;
  .history-item {
    display: inline-block;
    font-size: 12px;
    padding: 8px 14px;
    background-color: #efefef;
    margin: 10px 8px 0px 8px;
    border-radius: 10px;
  }
}
</style>
